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BACKGROUND OF THE INVENTION 
Field of the Invention 

5 

This invention relates to data processing systems. More particularly, this 
invention relates to the updating of computer files on data processing devices having 
wireless communication links with other data processing devices. 

10 Description of the Prior Art 

Data processing devices having wireless communication links with other data 
processing devices are becoming increasingly common. Examples of such devices are 
wireless connected notebook or laptop PCs, PDAs, smartphones and the like. 
15 Computer files stored on these wireless connected devices and used by them may 
require regular updating. An example of such files are computer virus definition data 
files and computer virus scanning engine files. Such files require regular updating to 
remain properly effective. 

20 With permanently connected data processing devices, such as conventional 

PCs connected by wired networks, relatively reliable and systematic update 
mechanisms and procedures may be put into place. However, wireless connected 
devices are generally subject to a more ad-hoc nature of connection and in some cases 
may never be connected to an individual other device for a sufficient period of time to 

25 enable a conventional updating mechanism and strategy to be effective. 

SUMMARY OF THE INVENTION 

Viewed fi:om one aspect the present invention provides a computer program 
30 product for controlling a target data processing device to update a current version of a 
file stored on a target data processing device, said computer program product 
comprising: 
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link forming logic operable to form a wireless communication link with an in- 
range data processing device storing a more up-to-data version of said file; 

portion determining logic operable to determine if a portion of said more up-to- 
date version of said file is already stored within said target data processing device 
5 within a store of portions of one or more different more up-to-date versions of said 
file; 

downloading logic operable to download said more up-to-date version of said 
file from said in-range data processing device following on from any portion of said 
more up-to-date version of said file already stored within said store; and 
10 when a full copy of said more up-to-date version of said file is stored on said 

target data processing device, version replacing logic operable to replace said current 
version of said file with said more up-to-date version of said file to form a new current 
version of said file and to discard from said store any portions of less up-to-date 
versions of said file than said new current version of said file. 

15 

The invention recognises that in the case of wireless connected data processing 
devices a different approach to the updating mechanism needs to be taken in order to 
deal with the situation that such devices are often only connected for short periods of 
time and at irregular intervals. Accordingly, the invention provides the ability to store 

20 portions of updates as and when they become available from the various in-range 
source devices that the target device may encounter and seek to complete these partial 
stored downloads when the opportunity arises. Since it cannot be guaranteed that the 
in-range devices the target device may encounter will all contain a common more up- 
to-date version of the file it is required to download, the target device is provided with 

25 the ability to store portions of a plurality of different more up-to-date versions such 
that the first of these to be completed can be used. Less up-to-date partially 
downloaded versions can at that stage be discarded as they will not subsequently be 
needed. 

30 Whilst it will be appreciated that the technique can be applied to a wide variety 

of computer files, such as for example corporate database type files, the invention is of 
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particularly utility in the field of anti- virus protection where the file may be an anti- 
computer virus definition data file or a computer anti- virus scanning engine file. 

It may be that the target device encounters an in-range device that does not 
5 itself have a full copy of a more up-to-date version of a desired computer file, but 
instead only has a portion of that computer file. Nevertheless, the target device may 
choose to download that portion of the more up-to-date computer file as it is available 
and then seek to complete that download from a different device at a later time. 

10 It may be that the in-range device is storing a plurality of versions of the 

desired computer file. A preferred strategy may be to start the downloading to the 
target device with the version of the computer file that will take least time to download 
to form a complete copy of that version of the computer file on the target device. In 
this way, the target device can seek to increase its chances of making at least some 

15 progress in its update status even if the connection time with the in-range device is 
short. 

It will be appreciated that the amount of storage capacity available on a typical 
wireless data processing device is relatively limited and accordingly the management 
20 of available storage space for use in this updating mechanism is a significant 
consideration. Accordingly, preferred embodiments of the invention include 
mechanisms for discarding partially completed versions of a computer file based upon 
one or more of the age of the computer file and the amount of data needing to be 
downloaded to complete that computer file, 

25 

In order to resist malicious interference with this downloading mechanism, 
particularly in the context of anti-virus systems, preferred embodiments of the 
invention authenticate the downloading process using digital signatures. 

30 It will be appreciated that a particular in-range device may itself be 

communicating with a further device which is not an in-range device to the target 
device. In this context the in-range device communicating with the target device can 
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effectively act as a data relay and can signal the target device that it is currently 
updating to a more up-to-date version of a file from a further device such that the 
target device may select that currently downloading version to itself download as parts 
or all of it become available. 

5 

It will be appreciated that the updating could be bi-directional and that two 
wireless connected devices could each have different computer files that are more up- 
to-date than the corresponding computer files stored upon the other device. In this 
circximstance the devices can exchange updates. 

10 

As well as providing a computer program for controlling processing operation 
in accordance with the above techniques, the invention also provides a method of 
updating a file and an apparatus for updating a file. 

15 The above, and other objects, features and advantages of this uivention will be 

apparent from the following detailed description of illustrative embodiments which is to 
be read in connection with the accompanying drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

20 

Figure 1 schematically illustrates a target data processing device connected at 
different times to different in-range devices storing different versions of a computer file; 

Figure 2 is a flow diagram illustrating the processing that may be performed by 
25 the target data processing device; and 

Figure 3 schematically illustrates a general purpose wireless data processing 
device of the type that may be used to implement the above described techniques. 



30 



DESCRIPTION OF THE PREFERRED EMBODIMENTS 
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Figure 1 illustrates a target wireless data processing device in the form of a PDA 
2. The target device 2 includes a wireless link 4 for connecting to similarly equipped 
other devices. At different points in time the target device 2 may be connected to an in- 
range PDA 4, a PC 6 connected via a wireless hub 8 and a further in-range PDA 8. 

5 

The target device 2 includes a memory 10 for storing a current version a of a 
computer file to be updated, such as an anti-computer virus definition data file or an anti- 
computer virus scanning engine file. 

10 The target device 2 also includes a memory 12 (this may be a different portion of 

the same memory as forms memory 10 or a separate memory) for storing partially 
completed more up-to-date versions of the computer files stored within the memory 10. 
In this example, the target device 2 has managed to download 50% of a version A fi-om 
the in-range PDA device 4, and 10% of the version C fi*om the PC 6, The target device 2 

1 5 was connected via a wireless link to these different devices at different times. At another 
time, the target device 2 was connected to the further in-range PDA device 8, but since 
this only stored a less up-to-date version % of the computer file, than that already held in 
complete form within memory 10 by the target device 2, no download was made from 
the further in-range PDA device 8, 

20 

Figure 2 is a flow diagram illustrating the processing performed by tiie target 
device 2. At step 12 the target device waits for connection to be estabUshed with an in- 
range device that is also running the update mechanism. When such a link is made, step 
13 checks if more than one other device is in range (e.g. at start-up multiple other devices 

25 may be encountered), and if so then selects a device for further interaction. The selection 
may be based on various criteria, such as the transfer speed of the connection, an estimate 
of the connection lifetime (e.g. based upon history information or information provided 
by the other device) or which device has the preferred file for download (as discussed 
later). Step 14 determines whether or not that in-range device has a more up-to-date 

30 version of the currentiy used complete version of the file stored in the memory 10. If the 
in-range device does not have a more up-to-date version, then processing returns to step 
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12. If a more up-to-date version is available in at least partial form within the in-range 
device, then processing proceeds to step 16. 

Step 16 determines whether more than one version of the file to be downloaded is 
5 present within the in-range device. If more than one version is present, then a selection as 
to which version should be downloaded first is made. This selection may be made to 
select the version which will take least time to download to the target device to form a 
complete more up-to-date version within the target device based upon those portions of 
the computer file already stored within the target device. Alternatively, a different 
10 strategy may be selected whereby the most up-to-date version available within the in- 
range device is selected irrespective of whether or not any of that version is already stored 
within the target device or how long it is estimated that download of that most up-to-date 
version will take. The selection of the strategy to be used can be set dependent upon 
corporate or individual user preferences. 

15 

Step 16 also serves to discard any currently partially downloaded portions of the 
file that may be necessary in order to make room within the memory 12 for the now to be 
downloaded new data. Again, different strategies may be used to select which data 
should be discarded. A simple strategy may discard the data relating to the least up-to- 
20 date version. Another strategy may replace or modify this strategy based upon the 
amount of data needing to be downloaded to complete the different versions currently 
stored within the memory 12. These strategy selections may again be made in 
dependence upon user or corporate preferences. 

25 At step 18 a determination is made as to whether or not some of the version of the 

file to be downloaded from the in-range device is already stored within the memory 12. 
If some is already stored, then processing proceeds to step 20 at which download is 
commenced fi*om the previous point reached within the file and the new data appended to 
the previously downloaded data. Alternatively, if no portion of the file to be downloaded 

30 is already stored, then processing proceeds to step 22 at which a fresh download of the 
complete file is initiated. 
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Step 24 serves to monitor for the download being terminated. The download may 
be terminated because the end of the file has been reached. Alternatively, the download 
may be terminated because the target device moves out-of-range of the in-range device 
from which the download was being made. Step 26 determines whether a complete new 
5 version of the file has been downloaded. If a complete new version has not been 
dovmloaded, then processing proceeds to step 12. 

If a complete new version has been downloaded as determined at step 26, then 
step 27 checks the digital signature on the downloaded file to check that it is authentic. If 

10 the file does not have the correct digital signature, then it is discarded at step 29 and 
processing retums to step 12. If the file does have the correct digital signature then step 
28 serves to replace the currently used version stored within the memory 10 with the new 
dovmloaded version. Step 30 then discards any partially complete buffered versions 
stored within the memory 12 that are less up-to-date than the newly downloaded 

15 complete version. Such old partially complete versions wall now not be needed since 
they would never be used to replace the more up-to-date version that has just been 
obtained in complete form. After step 30 processing retums to step 12. 

A particular wireless device may be in-range with a first device, but out-of-range 
20 with a second device. In these circumstances, it may be possible for the first device to act 
as a relay to the second device. The first device may itself already be downloading a file 
from the second device that it can then pass on to the particular device. Altematively, 
intermediate devices may act as simple relays (possibly bidirectional) of request for 
updating files among an extended network of devices even if the replaying device itself 
25 has no need for the files being requested. 

Figure 3 highly schematically illustrates the general form of a wireless data 
processing device 100, The wireless data processing device 100 includes a central 
processing unit 102, a read only memory 104, a random access memory 106, a non- 
30 volatile memory 108, such as a memory stick, a LCD user display 110, a touch screen 
user input device 112 and a wireless communication device 114, such as a Bluetoothor 
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802.11 module. The various components of the wireless data processing device 100 are 
connected via a common bus 116. 

In operation the central processing unit 102 executes computer program 
5 instructions stored within the read only memory 104, the random access memory 106 or 
the memory stick 108, or alternatively downloaded via the v^reless link 114. The 
random access memory 106 may be used as working memory, as may the memory stick 
108. The results of the data processing are displayed to a user via the LCD panel 110. 
Controlling user inputs are received via the touch screen input device 1 12 (or keyboard or 
1 0 stylus in alternative devices). 

The computer program controlled operation of the general purpose wireless data 
processing device 100 can carry out the above described techniques and methods m 
accordance with known programming techniques. Various different progrannming 
15 languages may be used and different architectures of wireless data processing device 
employed. The computer program may be distributed on a recordable media or 
dynamically downloaded via a wireless link. 

Although illustrative embodiments of the invention have been described in detail 
20 herein with reference to the accompanying drawings, it is to be understood that the 
invention is not hmited to those precise embodiments, and that various changes and 
modifications can be effected therein by one skilled in the art without departing firom the 
scope and spirit of the invention as defined by the appended claims. 



25 



